/**
 * 基于 axios 封装的请求模块
 */
import axios from 'axios'
import JSONbig from 'json-bigint'

// 创建一个 axios 实例，说白了就是复制了一个 axios
// 我们通过这个实例去发请求，把需要的配置配置给这个实例来处理
const request = axios.create({
  baseURL: 'http://api-toutiao-web.itheima.net',
  // 定义后端返回的原始数据的处理
  // 参数 data 就是后端返回的原始数据（未经处理的 JSON 格式字符串）
  transformResponse: [function (data) {
    // 后端返回的数据可能不是 JSON 格式字符串
    // 如果不是的话，那么 JSONbig.parse 调用就会报错
    // 所以我们使用 try...catch 来捕获异常，处理异常的发生
    try {
      // 如果转换成功，则直接把结果返回
      return JSONbig.parse(data)
    } catch (err) {
      // 如果转换失败，则进入这里
      // 我们在这里把数据原封不动的直接返回给请求使用
      return data
    }
  }]
})

// 请求拦截器
request.interceptors.request.use(function (config) {
  // 任何所有请求都会经过这里
  // config 是当前请求相关的配置信息对象，config是可以修改的
  // 在请求拦截器中统一获取token数据
  const user = JSON.parse(window.localStorage.getItem('admin-user'))

  // 判断用户是否登录，如果登录，则统一设置 token
  if (user) {
    config.headers.Authorization = `Bearer ${user.token}`
  }

  // 然后我们就可以在允许请求出去之前定制统一业务功能处理
  // 必须return config，否则请求发不出去，就会报错
  return config
}, function (error) {
  return Promise.reject(error)
})

// 响应拦截器
// axios.interceptors.response.use(function (response) {
//   return response
// }, function (error) {
//   return Promise.reject(error)
// })

// 导出请求方法
export default request
